/* =====================================================
   JUNKILEE — style.css
   Theme: Dark Forge · Charcoal × Fire (red/orange/amber)
   Fonts: Oswald (display) + Sora (body) + JetBrains Mono (labels)
   ===================================================== */

/* Reset handled by style.css */




/* ── VARIABLES ─────────────────────────────────────── */
:root {
  /* Core palette */
  --bg:        #111111;
  --bg2:       #181818;
  --bg3:       #202020;
  --bg4:       #2a2a2a;
  --bg5:       #333333;
  --border:    #2e2e2e;
  --border2:   #3a3a3a;

  /* Fire accents */
  --red:       #d63031;
  --red-dark:  #a51c1c;
  --orange:    #e17055;
  --amber:     #f0a500;
  --yellow:    #f9ca24;

  /* Fire gradient */
  --fire:      linear-gradient(135deg, #d63031 0%, #e17055 45%, #f0a500 100%);
  --fire-glow: 0 0 24px rgba(214,48,49,0.35);

  /* Text */
  --txt:       #f0ede6;
  --txt2:      #a8a09a;
  --txt3:      #666058;

  /* Fonts — kept in sync with style.css */
  --f-display: 'KnightWarrior', Georgia, serif;
  --f-body:    'DeatheMaachNcv', Georgia, serif;
  --f-mono:    'Lato', sans-serif;

  /* Layout */
  --nav-h:     64px;
  --sidebar-w: 420px;
  --r:         6px;
  --r-lg:      12px;
  --ease:      cubic-bezier(.25,.46,.45,.94);
  --ease-out:  cubic-bezier(.16,1,.3,1);
}





/* ── BUTTONS ───────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 24px;
  font-family: var(--f-mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase;
  border: 1px solid transparent; border-radius: var(--r); cursor: pointer;
  transition: all .22s var(--ease); white-space: nowrap; text-decoration: none;
}
.btn-fire {
  background: var(--fire); color: #fff; border-color: transparent;
  box-shadow: var(--fire-glow);
}
.btn-fire:hover { filter: brightness(1.12); transform: translateY(-1px); color: #fff; }
.btn-outline {
  background: transparent; color: var(--txt2); border-color: var(--border2);
}
.btn-outline:hover { border-color: var(--amber); color: var(--amber); }
.btn-ghost { background: var(--bg3); color: var(--txt2); border-color: var(--border); }
.btn-ghost:hover { background: var(--bg4); color: var(--txt); }
.btn-danger { background: rgba(214,48,49,.12); color: var(--red); border-color: rgba(214,48,49,.3); }
.btn-danger:hover { background: rgba(214,48,49,.2); }
.btn-full { width: 100%; }
.btn:disabled { opacity: .35; cursor: not-allowed; transform: none !important; filter: none !important; }
.btn-lg { padding: 15px 32px; font-size: .78rem; }


/* ═══════════════════════════════════════════════════
   NAVBAR
   ═══════════════════════════════════════════════════ */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; height: var(--nav-h); z-index: 500;
  background: rgba(17,17,17,.92); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
  transition: background .3s;
}
.nav-inner {
  max-width: 1320px; margin: 0 auto; padding: 0 24px; height: 100%;
  display: flex; align-items: center; gap: 32px;
}
.nav-logo {
  display: flex; align-items: center; gap: 10px; text-decoration: none; flex-shrink: 0;
}
.nav-logo-icon {
  width: 36px; height: 36px;
  background: var(--fire); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; box-shadow: var(--fire-glow);
}
.nav-logo-text {
  font-family: var(--f-display); font-size: 1.4rem; font-weight: 700;
  letter-spacing: .12em; color: var(--txt);
}
.nav-links {
  display: flex; align-items: center; gap: 28px; flex: 1; justify-content: center;
}
.nav-link {
  font-family: var(--f-mono); font-size: .68rem; letter-spacing: .16em;
  text-transform: uppercase; color: var(--txt2); text-decoration: none;
  position: relative; transition: color .2s;
}
.nav-link::after {
  content: ''; position: absolute; bottom: -4px; left: 0; right: 0; height: 1px;
  background: var(--red); transform: scaleX(0); transform-origin: left; transition: transform .25s var(--ease);
}
.nav-link:hover, .nav-link.active { color: var(--txt); }
.nav-link:hover::after, .nav-link.active::after { transform: scaleX(1); }
.nav-actions { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.nav-cart-btn {
  position: relative; background: var(--bg3); border: 1px solid var(--border2);
  border-radius: var(--r); padding: 8px 14px;
  display: flex; align-items: center; gap: 8px; cursor: pointer;
  color: var(--txt2); transition: all .2s;
  font-family: var(--f-mono); font-size: .7rem; letter-spacing: .08em;
}
.nav-cart-btn:hover { border-color: var(--red); color: var(--txt); background: var(--bg4); }
.nav-cart-btn svg { flex-shrink: 0; }
.cart-count-label { color: var(--amber); font-weight: 600; }
.cart-badge {
  position: absolute; top: -6px; right: -6px;
  background: var(--red); color: #fff;
  font-family: var(--f-mono); font-size: .58rem;
  min-width: 18px; height: 18px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center; padding: 0 4px;
  transition: transform .2s var(--ease-out);
}
.cart-badge.bump { transform: scale(1.4); }
.hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px;
}
.hamburger span {
  display: block; width: 22px; height: 1.5px; background: var(--txt2);
  transition: all .25s var(--ease); transform-origin: center;
}
.hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); background: var(--red); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); background: var(--red); }



/* ═══════════════════════════════════════════════════
   SEARCH BAR
   ═══════════════════════════════════════════════════ */
/* search layout handled by style.css */
.search-section { background: transparent; border-bottom: none; }

/* ═══════════════════════════════════════════════════
   CATEGORY PILLS
   ═══════════════════════════════════════════════════ */
.cat-section { padding: 16px 0; background: var(--bg2); border-bottom: 1px solid var(--border); }
.cat-wrap { display: flex; align-items: center; padding: 0 16px; }
.cat-arrow {
  flex-shrink: 0; width: 32px; height: 32px; background: var(--bg3);
  border: 1px solid var(--border); border-radius: var(--r);
  color: var(--txt2); font-size: 1.1rem; cursor: pointer; display: flex;
  align-items: center; justify-content: center; transition: all .2s;
}
.cat-arrow:hover { border-color: var(--red); color: var(--red); }
.cat-arrow:disabled { opacity: .3; cursor: default; }
.cat-track-wrap { flex: 1; overflow: hidden; }
.cat-track {
  display: flex; gap: 8px; padding: 2px 12px;
  transition: transform .4s var(--ease-out); width: max-content;
}
.cat-pill {
  flex-shrink: 0; 
  display: flex; 
  align-items: center; 
  padding: 7px 16px; 
  background: var(--bg3); 
  border: 1px solid var(--border);
  border-radius: 99px; 
  font-family: var(--f-mono); 
  font-size: .67rem;
  letter-spacing: .1em; 
  text-transform: uppercase; 
  color: var(--txt2);
  cursor: pointer; 
  transition: all .2s; 
  white-space: nowrap;
}
.cat-pill:hover { border-color: var(--border2); color: var(--txt); }
.cat-pill.active {
  background: var(--fire); border-color: transparent; color: #fff;
  box-shadow: var(--fire-glow);
}

/* ═══════════════════════════════════════════════════
   PRODUCTS PAGE LAYOUT
   ═══════════════════════════════════════════════════ */
.products-page { max-width: 1320px; margin: 0 auto; padding: 32px 24px 80px; }
.products-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 24px; gap: 16px; flex-wrap: wrap; }
.products-title { font-family: var(--f-display); font-size: 1.6rem; letter-spacing: .06em; }
.products-count { font-family: var(--f-mono); font-size: .68rem; color: var(--txt3); letter-spacing: .1em; }
.sort-select {
  background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r);
  color: var(--txt2); font-family: var(--f-mono); font-size: .68rem;
  padding: 7px 12px; outline: none; cursor: pointer; letter-spacing: .06em;
}
.sort-select:focus { border-color: var(--red); }

/* Grid */
.products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 18px;
}
@media(max-width:500px) { .products-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

/* ── PRODUCT CARD ──────────────────────────────────── */
.pcard {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden; cursor: pointer;
  transition: border-color .25s, transform .3s var(--ease), box-shadow .3s;
  animation: fadeUp .45s var(--ease-out) both;
  position: relative;
}
@keyframes fadeUp { from { opacity:0; transform: translateY(16px); } to { opacity:1; transform: translateY(0); } }
.pcard:hover { border-color: var(--red); transform: translateY(-3px); box-shadow: 0 8px 32px rgba(214,48,49,.15); }
.pcard-img {
  width: 100%; aspect-ratio: 1/1; overflow: hidden; background: var(--bg3); position: relative;
}
.pcard-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); display: block; }
.pcard:hover .pcard-img img { transform: scale(1.07); }
.pcard-img-placeholder {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 6px;
  background: linear-gradient(135deg, #1e1e1e, #252525);
}
.pcard-img-placeholder svg { opacity: .3; }
.pcard-badge {
  position: absolute; top: 10px; left: 10px;
  background: var(--fire); color: #fff;
  font-family: var(--f-mono); font-size: .58rem; letter-spacing: .1em;
  text-transform: uppercase; padding: 3px 8px; border-radius: 3px;
  box-shadow: var(--fire-glow);
}
.pcard-badge-out { background: var(--bg5); color: var(--txt3); box-shadow: none; }
.pcard-body { padding: 14px 14px 10px; }
.pcard-cat {
  font-family: var(--f-mono); font-size: .6rem; letter-spacing: .16em;
  text-transform: uppercase; color: var(--amber); margin-bottom: 4px;
}
.pcard-name {
  font-family: var(--f-display); font-size: 1rem; letter-spacing: .04em;
  color: #ffffff; line-height: 1.25; margin-bottom: 4px;
}
.pcard-material { font-size: .75rem; color: var(--txt3); margin-bottom: 10px; }
.pcard-footer { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.pcard-price { font-family: var(--f-mono); font-size: .82rem; color: #c8a96e; font-weight: 600; }
.pcard-stock { font-family: var(--f-mono); font-size: .6rem; color: var(--txt3); }
.pcard-atc {
  width: 34px; height: 34px; background: var(--bg4); border: 1px solid var(--border2);
  border-radius: var(--r); color: var(--txt2); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s; flex-shrink: 0;
}
.pcard-atc:hover { background: var(--red); border-color: var(--red); color: #fff; box-shadow: var(--fire-glow); }
.pcard-atc.added { background: #2ecc71; border-color: #2ecc71; color: #fff; }
.pcard-atc:disabled { opacity: .3; cursor: not-allowed; }

/* ═══════════════════════════════════════════════════
   CART SIDEBAR
   ═══════════════════════════════════════════════════ */
.cart-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.7);
  z-index: 800; opacity: 0; pointer-events: none;
  transition: opacity .3s;
}
.cart-overlay.open { opacity: 1; pointer-events: all; }
.cart-sidebar {
  position: fixed; top: 0; right: 0; bottom: 0; width: var(--sidebar-w);
  max-width: 100vw; background: var(--bg2);
  border-left: 1px solid var(--border);
  z-index: 900; display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .38s var(--ease-out);
  box-shadow: -8px 0 40px rgba(0,0,0,.5);
}
.cart-sidebar.open { transform: translateX(0); }
.cart-sidebar-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.cart-sidebar-title {
  font-family: var(--f-display); font-size: 1.3rem; letter-spacing: .08em;
  display: flex; align-items: center; gap: 10px;
}
.cart-item-count-tag {
  background: var(--red); color: #fff; font-family: var(--f-mono);
  font-size: .62rem; padding: 2px 8px; border-radius: 3px; letter-spacing: .06em;
}
.cart-close {
  background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r);
  width: 32px; height: 32px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--txt2); transition: all .2s;
}
.cart-close:hover { border-color: var(--red); color: var(--red); }
.cart-sidebar-body { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 12px; }
.cart-empty-state {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; color: var(--txt3);
}
.cart-empty-state svg { opacity: .2; }
.cart-empty-state p { font-family: var(--f-mono); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; }

/* Cart item row */
.cart-item {
  display: grid; grid-template-columns: 72px 1fr auto;
  gap: 12px; align-items: start;
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 12px;
  animation: fadeUp .3s var(--ease-out) both;
  transition: border-color .2s;
}
.cart-item:hover { border-color: var(--border2); }
.cart-item-img {
  width: 72px; height: 72px; border-radius: var(--r); object-fit: cover;
  background: var(--bg4);
}
.cart-item-img-ph {
  width: 72px; height: 72px; border-radius: var(--r); background: var(--bg4);
  display: flex; align-items: center; justify-content: center; font-size: 1.6rem; flex-shrink: 0;
}
.cart-item-name { font-family: var(--f-display); font-size: .9rem; letter-spacing: .03em; margin-bottom: 3px; }
.cart-item-meta { font-size: .72rem; color: var(--txt3); margin-bottom: 8px; }
.cart-item-qty-row { display: flex; align-items: center; gap: 8px; }
.qty-btn {
  width: 26px; height: 26px; background: var(--bg4); border: 1px solid var(--border2);
  border-radius: 4px; color: var(--txt); cursor: pointer;
  display: flex; align-items: center; justify-content: center; font-size: .9rem;
  transition: all .15s;
}
.qty-btn:hover { border-color: var(--amber); color: var(--amber); }
.qty-num { font-family: var(--f-mono); font-size: .78rem; min-width: 20px; text-align: center; }
.cart-item-right { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; padding-top: 2px; }
.cart-item-price { font-family: var(--f-mono); font-size: .78rem; color: var(--amber); white-space: nowrap; font-weight: 600; }
.cart-item-remove {
  background: none; border: none; cursor: pointer; color: var(--txt3);
  font-size: .65rem; font-family: var(--f-mono); letter-spacing: .08em;
  padding: 2px; transition: color .2s;
}
.cart-item-remove:hover { color: var(--red); }

/* Cart sidebar footer */
.cart-sidebar-footer {
  padding: 16px 20px; border-top: 1px solid var(--border); flex-shrink: 0;
  background: var(--bg2);
}
.cart-summary-rows { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.cart-summary-row {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-mono); font-size: .7rem; color: var(--txt2);
}
.cart-summary-row.total { color: var(--txt); font-size: .82rem; padding-top: 8px; border-top: 1px solid var(--border); margin-top: 4px; }
.cart-summary-row.total .val { color: var(--amber); font-size: .92rem; }
.cart-ctas { display: flex; flex-direction: column; gap: 8px; }
.cart-ctas .btn-fire { font-size: .72rem; }

/* ═══════════════════════════════════════════════════
   PRODUCT DETAIL PAGE
   ═══════════════════════════════════════════════════ */
.product-detail-wrap {
  max-width: 1100px; margin: calc(var(--nav-h) + 32px) auto 80px;
  padding: 0 24px;
  display: grid; grid-template-columns: 1fr 420px; gap: 48px; align-items: start;
}
@media(max-width:860px) {
  .product-detail-wrap { grid-template-columns: 1fr; gap: 28px; }
}
.pd-gallery { position: sticky; top: calc(var(--nav-h) + 20px); }
.pd-main-img {
  width: 100%; aspect-ratio: 1/1; border-radius: var(--r-lg);
  overflow: hidden; background: var(--bg3); position: relative;
  border: 1px solid var(--border); margin-bottom: 12px;
}
.pd-main-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pd-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(17,17,17,.8); border: 1px solid var(--border);
  color: var(--txt); width: 40px; height: 40px; border-radius: var(--r);
  display: flex; align-items: center; justify-content: center; cursor: pointer;
  transition: all .2s; font-size: 1.2rem; backdrop-filter: blur(4px);
}
.pd-arrow-prev { left: 12px; }
.pd-arrow-next { right: 12px; }
.pd-arrow:hover { background: var(--red); border-color: var(--red); }
.pd-thumbs { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; }
.pd-thumbs::-webkit-scrollbar { height: 3px; }
.pd-thumb {
  width: 72px; height: 72px; flex-shrink: 0; border-radius: var(--r);
  overflow: hidden; border: 2px solid transparent;
  cursor: pointer; transition: all .2s; background: var(--bg3);
}
.pd-thumb img { width: 100%; height: 100%; object-fit: cover; }
.pd-thumb.active { border-color: var(--amber); box-shadow: 0 0 0 1px var(--amber); }
.pd-thumb:hover { border-color: var(--border2); }

/* Info panel */
.pd-info { }
.pd-cat { font-family: var(--f-mono); font-size: .64rem; letter-spacing: .18em; text-transform: uppercase; color: var(--amber); margin-bottom: 8px; }
.pd-name { font-family: var(--f-display); font-size: clamp(1.5rem, 3vw, 2.2rem); letter-spacing: .04em; line-height: 1.15; margin-bottom: 6px; }
.pd-price { font-family: var(--f-mono); font-size: 1.3rem; color: var(--amber); font-weight: 600; margin-bottom: 16px; }
.pd-divider { height: 1px; background: var(--border); margin: 18px 0; }
.pd-label { font-family: var(--f-mono); font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; color: var(--txt2); margin-bottom: 10px; }

/* Color swatches */
.pd-colors { display: flex; gap: 10px; margin-bottom: 4px; }
.pd-swatch {
  width: 28px; height: 28px; border-radius: 50%; border: 2px solid transparent;
  cursor: pointer; transition: all .2s;
}
.pd-swatch.active { border-color: var(--txt); box-shadow: 0 0 0 2px var(--txt); }
.pd-swatch:hover { transform: scale(1.15); }

/* Profile chips */
.pd-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.pd-chip {
  padding: 7px 16px; background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--r); font-family: var(--f-mono); font-size: .68rem;
  letter-spacing: .08em; text-transform: uppercase; color: var(--txt2);
  cursor: pointer; transition: all .2s;
}
.pd-chip:hover { border-color: var(--border2); color: var(--txt); }
.pd-chip.active { background: var(--fire); border-color: transparent; color: #fff; box-shadow: var(--fire-glow); }

/* Qty row */
.pd-qty-row { display: flex; align-items: center; gap: 12px; }
.pd-qty-num {
  width: 52px; text-align: center; background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--r); padding: 8px; font-family: var(--f-mono); font-size: .9rem;
  color: var(--txt); outline: none;
}
.pd-qty-num:focus { border-color: var(--amber); }
.pd-qty-btn {
  width: 38px; height: 38px; background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--r); color: var(--txt); cursor: pointer; font-size: 1.1rem;
  display: flex; align-items: center; justify-content: center; transition: all .2s;
}
.pd-qty-btn:hover { border-color: var(--amber); color: var(--amber); }
.pd-atc { padding: 16px 28px; font-size: .82rem; margin-top: 8px; }
.pd-desc { font-size: .88rem; color: var(--txt2); line-height: 1.7; }
.pd-stock-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--f-mono); font-size: .64rem; letter-spacing: .1em;
  padding: 5px 10px; border-radius: 3px; text-transform: uppercase;
}
.pd-in-stock { background: rgba(46,204,113,.12); color: #2ecc71; border: 1px solid rgba(46,204,113,.2); }
.pd-low-stock { background: rgba(240,165,0,.12); color: var(--amber); border: 1px solid rgba(240,165,0,.2); }
.pd-out-stock { background: rgba(214,48,49,.1); color: var(--red); border: 1px solid rgba(214,48,49,.2); }

/* ═══════════════════════════════════════════════════
   CART PAGE (full page)
   ═══════════════════════════════════════════════════ */
.cart-page-wrap {
  max-width: 1100px; margin: calc(var(--nav-h) + 32px) auto 80px;
  padding: 0 24px;
}
.cart-page-header { margin-bottom: 28px; }
.cart-page-title { font-family: var(--f-display); font-size: 2rem; letter-spacing: .06em; }
.cart-page-subtitle { font-family: var(--f-mono); font-size: .7rem; color: var(--txt3); letter-spacing: .1em; margin-top: 4px; }
.cart-page-layout {
  display: grid; grid-template-columns: 1fr 360px; gap: 28px; align-items: start;
}
@media(max-width:900px) { .cart-page-layout { grid-template-columns: 1fr; } }
.cart-page-items { display: flex; flex-direction: column; gap: 14px; }
.cart-page-item {
  display: grid; grid-template-columns: 100px 1fr auto;
  gap: 16px; align-items: start;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 16px;
  transition: border-color .2s;
}
@media(max-width:500px) { .cart-page-item { grid-template-columns: 80px 1fr; } }
.cart-page-item:hover { border-color: var(--border2); }
.cart-page-img {
  width: 100px; height: 100px; border-radius: var(--r); object-fit: cover; background: var(--bg3);
}
@media(max-width:500px) { .cart-page-img { width: 80px; height: 80px; } }
.cart-page-item-name { font-family: var(--f-display); font-size: 1rem; margin-bottom: 3px; }
.cart-page-item-meta { font-size: .75rem; color: var(--txt3); margin-bottom: 10px; }
.cart-page-item-price { font-family: var(--f-mono); font-size: .8rem; color: var(--amber); font-weight: 600; }
.cart-page-subtotal { font-family: var(--f-mono); font-size: .82rem; color: var(--txt); white-space: nowrap; font-weight: 600; }
.cart-page-remove { font-family: var(--f-mono); font-size: .62rem; color: var(--txt3); background: none; border: none; cursor: pointer; letter-spacing: .08em; margin-top: 8px; transition: color .2s; }
.cart-page-remove:hover { color: var(--red); }

/* Order summary sidebar */
.order-summary {
  background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 24px; position: sticky; top: calc(var(--nav-h) + 20px);
}
.order-summary h3 { font-family: var(--f-display); font-size: 1.2rem; letter-spacing: .06em; margin-bottom: 18px; }
.order-rows { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.order-row {
  display: flex; justify-content: space-between;
  font-family: var(--f-mono); font-size: .72rem; color: var(--txt2);
}
.order-divider { height: 1px; background: var(--border); margin: 12px 0; }
.order-total { display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: .88rem; margin-bottom: 20px; }
.order-total .label { color: var(--txt); }
.order-total .val { color: var(--amber); font-size: 1rem; }
.discount-row { display: flex; gap: 8px; margin-bottom: 16px; }
.discount-input {
  flex: 1; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r);
  padding: 10px 14px; font-family: var(--f-mono); font-size: .72rem; color: var(--txt);
  outline: none; letter-spacing: .06em; transition: border-color .2s;
}
.discount-input::placeholder { color: var(--txt3); }
.discount-input:focus { border-color: var(--amber); }
.delivery-info {
  background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r);
  padding: 14px; margin-bottom: 16px;
}
.delivery-info-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.delivery-info-header span { font-family: var(--f-mono); font-size: .68rem; color: var(--txt2); letter-spacing: .1em; text-transform: uppercase; }
.delivery-info-header a { font-family: var(--f-mono); font-size: .65rem; color: var(--amber); }
.delivery-info p { font-size: .82rem; color: var(--txt2); line-height: 1.5; }




/* ═══════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════ */
.footer { background: var(--bg2); border-top: 1px solid var(--border); padding: 48px 24px 24px; }
.footer-inner { max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
@media(max-width:800px) { .footer-inner { grid-template-columns: 1fr 1fr; } }
@media(max-width:480px) { .footer-inner { grid-template-columns: 1fr; } }
.footer-brand .nav-logo-text { font-size: 1.6rem; display: block; margin-bottom: 12px; }
.footer-brand p { font-size: .85rem; color: var(--txt3); line-height: 1.7; font-style: italic; }
.footer-col h4 { font-family: var(--f-mono); font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--amber); margin-bottom: 14px; }
.footer-col a { display: block; font-size: .82rem; color: var(--txt3); text-decoration: none; margin-bottom: 8px; transition: color .2s; }
.footer-col a:hover { color: var(--txt); }
.footer-bottom { max-width: 1320px; margin: 0 auto; padding-top: 20px; border-top: 1px solid var(--border); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.footer-bottom p { font-family: var(--f-mono); font-size: .62rem; color: var(--txt3); opacity: .5; letter-spacing: .06em; }



/* ═══════════════════════════════════════════════════
   AUTH PAGE
   ═══════════════════════════════════════════════════ */
.auth-page { min-height: 100svh; display: flex; align-items: center; justify-content: center; padding: calc(var(--nav-h) + 24px) 24px 60px; }
.auth-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 36px; width: 100%; max-width: 440px; }
.auth-tabs { display: flex; gap: 0; margin-bottom: 28px; border-bottom: 1px solid var(--border); }
.auth-tab { flex: 1; background: none; border: none; border-bottom: 2px solid transparent; padding: 10px 0; margin-bottom: -1px; font-family: var(--f-mono); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--txt3); cursor: pointer; transition: all .2s; }
.auth-tab.active { border-bottom-color: var(--red); color: var(--red); }
.form-group { margin-bottom: 16px; }
.form-label { display: block; font-family: var(--f-mono); font-size: .62rem; letter-spacing: .15em; text-transform: uppercase; color: var(--txt2); margin-bottom: 7px; }
.form-input { width: 100%; background: var(--bg3); border: 1px solid var(--border2); border-radius: var(--r); padding: 12px 15px; font-family: var(--f-body); font-size: .88rem; color: var(--txt); outline: none; transition: border-color .2s, box-shadow .2s; }
.form-input:focus { border-color: var(--red); box-shadow: 0 0 0 2px rgba(214,48,49,.1); }
.form-input::placeholder { color: var(--txt3); }
.input-wrap { position: relative; }
.toggle-pw { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; font-size: .85rem; opacity: .4; transition: opacity .2s; }
.toggle-pw:hover { opacity: 1; }
.auth-switch { text-align: center; margin-top: 14px; font-family: var(--f-mono); font-size: .65rem; color: var(--txt3); letter-spacing: .06em; }
.auth-switch a { color: var(--amber); }
.otp-row { display: flex; gap: 8px; justify-content: center; margin-bottom: 20px; }
.otp-box { width: 46px; height: 58px; text-align: center; background: var(--bg3); border: 1px solid var(--border2); border-radius: var(--r); font-family: var(--f-display); font-size: 1.7rem; color: var(--amber); outline: none; transition: border-color .2s; }
.otp-box:focus { border-color: var(--red); box-shadow: 0 0 0 2px rgba(214,48,49,.1); }
.profile-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 36px; text-align: center; max-width: 440px; width: 100%; }
.profile-av { width: 72px; height: 72px; background: var(--fire); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--f-display); font-size: 2rem; color: #fff; margin: 0 auto 16px; box-shadow: var(--fire-glow); }
.profile-name { font-family: var(--f-display); font-size: 1.8rem; letter-spacing: .06em; margin-bottom: 4px; }
.profile-email { font-family: var(--f-mono); font-size: .72rem; color: var(--txt3); margin-bottom: 4px; }
.profile-since { font-family: var(--f-mono); font-size: .62rem; color: var(--txt3); opacity: .5; margin-bottom: 24px; }
.profile-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

/* ═══════════════════════════════════════════════════
   RESPONSIVE — NAVBAR MOBILE
   ═══════════════════════════════════════════════════ */
@media(max-width: 768px) {
  /* Mobile nav — slide-in sidebar from the right */
  .nav-links {
    display: flex !important;          /* override any display:none */
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    position: fixed;
    top: 0; right: 0;
    width: 75vw; max-width: 300px;
    height: 100dvh;
    background: var(--bg, #0e0e0e);
    border-left: 1px solid var(--border, rgba(255,255,255,0.08));
    padding: 80px 28px 40px;
    z-index: 1100;
    transform: translateX(100%);
    transition: transform 0.32s cubic-bezier(0.4,0,0.2,1);
    overflow-y: auto;
    box-shadow: -8px 0 32px rgba(0,0,0,0.45);
  }
  .nav-links.open {
    transform: translateX(0);
  }
  .nav-link {
    font-family: var(--f-mono);
    font-size: 1rem !important;
    letter-spacing: 0.08em;
    padding: 12px 0;
    width: 100%;
    border-bottom: 1px solid var(--border, rgba(255,255,255,0.06));
    color: var(--txt1, #e8e0d0);
  }
  .nav-link:last-child { border-bottom: none; }
  .hamburger { display: flex; }
  :root { --sidebar-w: 100vw; }
  .cart-page-layout { grid-template-columns: 1fr; }
  .order-summary { position: static; }
}
@media(max-width: 500px) {
  .nav-cart-btn .cart-count-label { display: none; }
}

/* ── SPINNER ───────────────────────────────────────── */
.spinner { width: 28px; height: 28px; border: 2px solid var(--border2); border-top-color: var(--red); border-radius: 50%; animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }


















/*PRODUCT.html*/

      :root {
      --bg3:       var(--bg-3);
      --bg4:       var(--bg-4);
      --bg5:       #252525;
      --txt:       var(--cream);
      --txt2:      var(--cream-muted);
      --txt3:      #6b6460;
      --amber:     var(--gold);
      --border2:   var(--border-2);
      --f-display: var(--font-display); /* KnightWarrior */
      --f-mono:    var(--font-mono);
      --r:         var(--radius);
      --r-lg:      var(--radius-lg);
      --fire:      linear-gradient(135deg, #c0392b, #e67e22);
      --fire-glow: 0 0 24px rgba(214, 48, 49, 0.35);
    }

    /* ── PRODUCT PAGE SPECIFIC ─────────────────────── */
    .pd-page {
      max-width: 1200px;
      margin: calc(var(--nav-h) + 40px) auto 80px;
      padding: 0 24px;
    }

    /* Breadcrumb */
    .pd-breadcrumb {
      display: flex; align-items: center; gap: 8px;
      font-family: var(--f-mono); font-size: .65rem;
      letter-spacing: .1em; color: var(--txt3);
      margin-bottom: 32px; text-transform: uppercase;
    }
    .pd-breadcrumb a { color: var(--txt3); text-decoration: none; transition: color .2s; }
    .pd-breadcrumb a:hover { color: var(--amber); }
    .pd-breadcrumb span { color: var(--border2); }

    /* Layout */
    .pd-layout {
      display: grid;
      grid-template-columns: 1fr 460px;
      gap: 56px;
      align-items: start;
    }

    /* Gallery */
    .pd-gallery { position: sticky; top: calc(var(--nav-h) + 24px); }

    .pd-main-wrap {
      position: relative;
      aspect-ratio: 1/1;
      border-radius: var(--r-lg);
      overflow: hidden;
      background: var(--bg3);
      border: 1px solid var(--border);
      margin-bottom: 14px;
      cursor: zoom-in;
    }
    .pd-main-img {
      width: 100%; height: 100%; object-fit: cover;
      display: block;
      transition: transform .4s var(--ease);
    }
    .pd-main-wrap:hover .pd-main-img { transform: scale(1.04); }
    .pd-main-placeholder {
      width: 100%; height: 100%;
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      gap: 12px; background: linear-gradient(135deg, var(--bg3), var(--bg4));
    }
    .pd-main-placeholder .ph-icon { font-size: 5rem; opacity: .15; }
    .pd-main-placeholder .ph-label {
      font-family: var(--f-mono); font-size: .62rem; letter-spacing: .18em;
      text-transform: uppercase; color: var(--txt3);
    }

    .pd-gallery-arrow {
      position: absolute; top: 50%; transform: translateY(-50%);
      width: 38px; height: 38px;
      background: rgba(17,17,17,.85); backdrop-filter: blur(8px);
      border: 1px solid var(--border2); border-radius: var(--r);
      color: var(--txt); cursor: pointer; font-size: 1.1rem;
      display: flex; align-items: center; justify-content: center;
      transition: all .2s; z-index: 2;
    }
    .pd-gallery-arrow:hover { background: var(--red); border-color: var(--red); box-shadow: var(--fire-glow); }
    .pd-gallery-arrow.prev { left: 12px; }
    .pd-gallery-arrow.next { right: 12px; }

    /* Image count badge */
    .pd-img-counter {
      position: absolute; bottom: 12px; right: 12px;
      background: rgba(17,17,17,.8); backdrop-filter: blur(4px);
      border: 1px solid var(--border); border-radius: 3px;
      font-family: var(--f-mono); font-size: .62rem; letter-spacing: .08em;
      color: var(--txt2); padding: 4px 9px; z-index: 2;
    }

    /* Thumbs */
    .pd-thumbs {
      display: flex; gap: 10px; overflow-x: auto; padding-bottom: 4px;
    }
    .pd-thumbs::-webkit-scrollbar { height: 3px; }
    .pd-thumbs::-webkit-scrollbar-thumb { background: var(--bg5); border-radius: 2px; }

    .pd-thumb {
      width: 80px; height: 80px; flex-shrink: 0;
      border-radius: var(--r); overflow: hidden;
      border: 2px solid var(--border);
      cursor: pointer; transition: all .2s;
      background: var(--bg3);
      display: flex; align-items: center; justify-content: center;
    }
    .pd-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .pd-thumb .th-icon { font-size: 1.8rem; opacity: .35; }
    .pd-thumb:hover { border-color: var(--border2); }
    .pd-thumb.active { border-color: var(--amber); box-shadow: 0 0 0 1px var(--amber); }

    /* ── INFO PANEL ──────────────────────────────── */
    .pd-info {}

    .pd-cat-tag {
      display: inline-flex; align-items: center; gap: 6px;
      font-family: var(--f-mono); font-size: .62rem; letter-spacing: .16em;
      text-transform: uppercase; color: var(--amber);
      margin-bottom: 10px;
    }

    .pd-title {
      font-family: var(--f-display); font-weight: 700;
      font-size: clamp(1.6rem, 3vw, 2.4rem);
      letter-spacing: .04em; line-height: 1.1;
      color: var(--txt); margin-bottom: 10px;
    }

    .pd-price-row {
      display: flex; align-items: baseline; gap: 12px;
      margin-bottom: 16px;
    }
    .pd-price {
      font-family: var(--f-mono); font-size: 1.5rem;
      color: var(--amber); font-weight: 600;
    }

    .pd-stock-tag {
      font-family: var(--f-mono); font-size: .62rem; letter-spacing: .1em;
      text-transform: uppercase; padding: 4px 10px; border-radius: 3px;
    }
    .pd-in-stock  { background: rgba(46,204,113,.1);  color: #2ecc71; border: 1px solid rgba(46,204,113,.2); }
    .pd-low-stock { background: rgba(240,165,0,.1);  color: var(--amber); border: 1px solid rgba(240,165,0,.2); }
    .pd-out-stock { background: rgba(214,48,49,.1);  color: var(--red);   border: 1px solid rgba(214,48,49,.2); }

    .pd-desc {
      font-size: .9rem; color: var(--txt2); line-height: 1.75;
      border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
      padding: 16px 0; margin-bottom: 20px;
    }

    /* Option sections */
    .pd-option-label {
      font-family: var(--f-mono); font-size: .62rem; letter-spacing: .18em;
      text-transform: uppercase; color: var(--txt3);
      margin-bottom: 10px; display: block;
    }
    .pd-option-section { margin-bottom: 20px; }

    /* Color swatches */
    .pd-swatches { display: flex; gap: 10px; }
    .pd-swatch {
      width: 30px; height: 30px; border-radius: 50%;
      border: 2px solid transparent; cursor: pointer; transition: all .2s;
      position: relative;
    }
    .pd-swatch.active {
      border-color: var(--txt);
      box-shadow: 0 0 0 2px var(--bg), 0 0 0 4px var(--txt);
    }
    .pd-swatch:hover { transform: scale(1.15); }
    .pd-swatch-tooltip {
      position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%);
      background: var(--bg4); border: 1px solid var(--border2);
      border-radius: 3px; padding: 3px 8px;
      font-family: var(--f-mono); font-size: .6rem; letter-spacing: .06em;
      color: var(--txt); white-space: nowrap; pointer-events: none;
      opacity: 0; transition: opacity .15s;
    }
    .pd-swatch:hover .pd-swatch-tooltip { opacity: 1; }

    /* Profile chips */
    .pd-chips { display: flex; gap: 8px; flex-wrap: wrap; }
    .pd-chip {
      padding: 8px 18px;
      background: var(--bg3); border: 1px solid var(--border);
      border-radius: var(--r); font-family: var(--f-mono);
      font-size: .68rem; letter-spacing: .1em; text-transform: uppercase;
      color: var(--txt2); cursor: pointer; transition: all .2s;
    }
    .pd-chip:hover { border-color: var(--border2); color: var(--txt); }
    .pd-chip.active {
      background: var(--fire); border-color: transparent; color: #fff;
      box-shadow: var(--fire-glow);
    }

    /* Qty row */
    .pd-qty-row {
      display: flex; align-items: center; gap: 0;
      background: var(--bg3); border: 1px solid var(--border);
      border-radius: var(--r); overflow: hidden; width: fit-content;
    }
    .pd-qty-minus, .pd-qty-plus {
      width: 44px; height: 44px; background: none; border: none;
      color: var(--txt); cursor: pointer; font-size: 1.2rem;
      display: flex; align-items: center; justify-content: center;
      transition: all .15s; font-family: var(--f-mono);
    }
    .pd-qty-minus:hover { background: var(--bg4); color: var(--red); }
    .pd-qty-plus:hover  { background: var(--bg4); color: var(--amber); }
    .pd-qty-val {
      min-width: 48px; text-align: center;
      font-family: var(--f-mono); font-size: .9rem; color: var(--txt);
      border-left: 1px solid var(--border); border-right: 1px solid var(--border);
      padding: 0 4px; height: 44px; line-height: 44px;
    }

    /* ATC button */
    .pd-atc-btn {
      width: 100%; padding: 17px;
      font-family: var(--f-mono); font-size: .78rem; letter-spacing: .15em;
      text-transform: uppercase; margin-top: 8px;
      position: relative; overflow: hidden;
    }
    .pd-atc-btn::after {
      content: ''; position: absolute; inset: 0;
      background: rgba(255,255,255,0); transition: background .2s;
    }
    .pd-atc-btn:hover::after { background: rgba(255,255,255,.06); }

    /* Wishlist / share row */
    .pd-actions-row {
      display: flex; gap: 10px; margin-top: 12px;
    }
    .pd-action-btn {
      flex: 1; padding: 11px;
      background: var(--bg3); border: 1px solid var(--border);
      border-radius: var(--r); color: var(--txt2); cursor: pointer;
      font-family: var(--f-mono); font-size: .65rem; letter-spacing: .1em;
      text-transform: uppercase; display: flex; align-items: center;
      justify-content: center; gap: 7px; transition: all .2s;
    }
    .pd-action-btn:hover { border-color: var(--border2); color: var(--txt); }

    /* Details list */
    .pd-details {
      margin-top: 24px; border-top: 1px solid var(--border); padding-top: 20px;
    }
    .pd-details-title {
      font-family: var(--f-mono); font-size: .62rem; letter-spacing: .18em;
      text-transform: uppercase; color: var(--txt3); margin-bottom: 12px;
      cursor: pointer; display: flex; align-items: center; justify-content: space-between;
    }
    .pd-details-grid {
      display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
    }
    .pd-detail-item {
      background: var(--bg3); border: 1px solid var(--border);
      border-radius: var(--r); padding: 12px 14px;
    }
    .pd-detail-label { font-family: var(--f-mono); font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; color: var(--txt3); margin-bottom: 3px; }
    .pd-detail-val { font-size: .85rem; color: var(--txt); font-family: var(--f-mono); }

    /* Related products */
    .pd-related { max-width: 1200px; margin: 0 auto 80px; padding: 0 24px; }
    .pd-related-header {
      display: flex; align-items: baseline; gap: 16px; margin-bottom: 20px;
      border-top: 1px solid var(--border); padding-top: 40px;
    }
    .pd-related-title { font-family: var(--f-display); font-size: 1.5rem; letter-spacing: .06em; }
    .pd-related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 16px; }



    
    /* Loading skeleton */
    .pd-skeleton {
      background: linear-gradient(90deg, var(--bg3) 25%, var(--bg4) 50%, var(--bg3) 75%);
      background-size: 200% 100%;
      animation: shimmer 1.4s infinite;
      border-radius: var(--r);
    }
    @keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

    /* Error state */
    .pd-error {
      text-align: center; padding: 80px 24px;
    }
    .pd-error h2 { font-family: var(--f-display); font-size: 2rem; margin-bottom: 10px; letter-spacing: .06em; }
    .pd-error p { color: var(--txt3); font-style: italic; margin-bottom: 24px; }

    /* ── RESPONSIVE ──────────────────────────────── */
    @media(max-width: 900px) {
      .pd-layout { grid-template-columns: 1fr; gap: 32px; }
      .pd-gallery { position: static; }
    }
    @media(max-width: 500px) {
      .pd-thumb { width: 64px; height: 64px; }
      .pd-details-grid { grid-template-columns: 1fr; }
    }

/* ═══════════════════════════════════════════════════════
   NEW ARRIVAL CAROUSEL
════════════════════════════════════════════════════════ */

.new-arrival-section {
  padding: 28px 0 0;
  overflow: hidden;
  background: transparent;
}

.na-header {
  padding: 0 24px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}

/* .na-label {
  font-family: var(--f-mono);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--acc);
} */

/* The viewport — clips overflow so cards slide out of view */
.na-track-wrap {
  width: 100%;
  overflow: hidden;
  /* Fade edges */
  mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%);
}

/* The moving belt */
.na-track {
  display: flex;
  gap: 16px;
  width: max-content;
  padding: 4px 16px 20px;
  will-change: transform;
}

/* Individual card */
.na-card {
  flex: 0 0 auto;
  width: 160px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform .2s, border-color .2s, box-shadow .2s;
  cursor: pointer;
  display: block;
}

.na-card:hover {
  transform: translateY(-4px) scale(1.02);
  border-color: var(--acc);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.na-card-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  background: var(--bg2);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.na-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.na-card-icon {
  font-size: 2.4rem;
  opacity: .6;
}

.na-badge {
  position: absolute;
  top: 6px;
  left: 6px;
  background: var(--acc);
  color: #fff;
  font-family: var(--f-mono);
  font-size: .6rem;
  letter-spacing: .06em;
  padding: 2px 7px;
  border-radius: 4px;
}

.na-badge-out {
  background: #555;
}

.na-card-body {
  padding: 9px 10px 10px;
}

.na-card-name {
  /* font-family: var(--f-sans);
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--txt1);
  margin-bottom: 3px; */

  font-family: var(--font-display);
  font-size: 0.78rem;
  color: var(--cream);
  letter-spacing: 0.05em;
  text-transform: uppercase;
    white-space: nowrap;
margin-bottom: 3px;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}

.na-card-price {
  font-family: var(--f-mono);
  font-size: .7rem;
  color: var(--acc);
}

@media (max-width: 600px) {
  .na-card { width: 130px; }
}

/* ── MOBILE NAV CLOSE BUTTON ────────────────────────── */
.mobile-nav-close {
  display: none;
  position: absolute;
  top: 20px; right: 20px;
  background: none;
  border: none;
  color: var(--txt, #e8e0d0);
  cursor: pointer;
  padding: 6px;
  opacity: 0.6;
  transition: opacity 0.2s;
}
.mobile-nav-close:hover { opacity: 1; }
@media (max-width: 768px) {
  .mobile-nav-close { display: flex; }
}


/* ── PRODUCT NAME FONT OVERRIDE (style 2) ─────────────── */
.pcard-name,
.cart-item-name,
.na-card-name,
.pd-name,
.pd-title {
  font-family: 'Ponter Alt', sans-serif;
  font-weight: 100;
  letter-spacing: 0.08em;
  color: #ffffff;
  -webkit-text-stroke: 0px;
}



/* ── League Gothic @font-face ────────────────────────────── */
@font-face {
  font-family: 'League Gothic';
  src: url('./fonts/league-gothic.regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* ── Carousel card price → #c8a96e always ────────────────── */
.na-card-price {
  color: #c8a96e !important;
}

/* ── Footer body text → Lato ───────────────────── */
.footer-brand p,
.footer-contact-row,
.footer-contact-row a,
.footer-contact-row span,
.footer-bottom p {
  font-family: 'Lato', sans-serif;
  font-style: normal;
  letter-spacing: 0.03em;
}
